# **NEC 304**

# **STLD**

Sequential Circuits: Latches

Rajeev Pandey
Department Of ECE
rajeevvce2007@gmail.com

#### **Overview**

- ° Circuits require memory to store intermediate data
- Sequential circuits use a periodic signal to determine when to store values.
  - A clock signal can determine storage times
  - Clock signals are periodic
- ° Single bit storage element is a flip flop
- ° A basic type of flip flop is a latch
- ° Latches are made from logic gates
  - NAND, NOR, AND, OR, Inverter

## The story so far ...

- Cogical operations which respond to combinations of inputs to produce an output.
  - Call these combinational logic circuits.
- ° For example, can add two numbers. But:
  - No way of adding two numbers, then adding a third (a sequential operation);
  - No way of remembering or storing information after inputs have been removed.
- To handle this, we need sequential logic capable of storing intermediate (and final) results.

# **Sequential Circuits**



# **Cross-coupled Inverters**

° A stable value can be stored at inverter outputs



#### S-R Latch with NORs



- S-R latch made from cross-coupled NORs
- $^{\circ}$  If Q = 1, set state
- ° If Q = 0, reset state
- Usually S=0 and R=0
- S=1 and R=1 generates unpredictable results

#### S-R Latch with NANDs



| S | R | Q      | Q'       | _          |
|---|---|--------|----------|------------|
| 0 | 0 | 1      | 1        | Disallowed |
| 0 | 1 | 1      | 0        | Set        |
| 1 | 0 | 0      | 1        | Reset      |
| 1 | 1 | 0<br>1 | <u>1</u> | Store      |

- Latch made from cross-coupled NANDs
- ° Sometimes called S'-R' latch
- ° Usually S=1 and R=1
- S=0 and R=0 generates unpredictable results

## S-R Latches



| S | R | Q | Q |             |  |
|---|---|---|---|-------------|--|
| 1 | 0 | 1 | 0 | Sat atata   |  |
| 0 | 0 | 1 | 0 | Set state   |  |
| 0 | 1 | 0 | 1 |             |  |
| 0 | 0 | 0 | 1 | Reset state |  |
| 1 | 1 | 0 | 0 | Undefined   |  |

(b) Function table



| S | R | Q | Q |             |  |
|---|---|---|---|-------------|--|
| 0 | 1 | 1 | 0 | Set state   |  |
| 1 | 1 | 1 | 0 |             |  |
| 1 | 0 | 0 | 1 |             |  |
| 1 | 1 | 0 | 1 | Reset state |  |
| 0 | 0 | 1 | 1 | Undefined   |  |

(b) Function table

## S-R Latch with control input



| C           | S           | R                | Next state of $Q$                                             |
|-------------|-------------|------------------|---------------------------------------------------------------|
| 0<br>1<br>1 | X<br>0<br>0 | X<br>0<br>1<br>0 | No change No change $Q = 0$ ; Reset state $Q = 1$ ; set state |
| 1           | 1           | 1                | Indeterminate                                                 |

(b) Function table

Fig. 5-5 SR Latch with Control Input

- Occasionally, desirable to avoid latch changes
- $^{\circ}$  C = 0 disables all latch state changes
- $^{\circ}$  Control signal enables data change when C = 1
- Right side of circuit same as ordinary S-R latch.

## **NOR S-R Latch with Control Input**

# Latch is level-sensitive, in regards to C

Only stores data if C' = 0



 $^{\circ}$  Q<sub>0</sub> indicates the previous state (the previously stored value)



| D | С | Q Q'      |
|---|---|-----------|
| 0 | 1 | 0 1       |
| 1 | 1 | 1 0       |
| X | 0 | $Q_0 Q_0$ |

| XYCQQ'                                                                                   |       |
|------------------------------------------------------------------------------------------|-------|
| 0 0 1 Q <sub>0</sub> Q <sub>0</sub> ' Store<br>0 1 1 0 1 Reset                           |       |
| 0 1 1 0 1 Reset                                                                          |       |
| 1 0 1 1 0 Set                                                                            |       |
| 1 1 1 1 Disal                                                                            | lowed |
| 0 1 1 0 1 Reset 1 0 1 1 0 Set 1 1 1 1 Disall X X 0 Q <sub>0</sub> Q <sub>0</sub> ' Store |       |



| D | С | Q     | Q'    |
|---|---|-------|-------|
| 0 | 1 | 0     | 1     |
| 1 | 1 | 1     | 0     |
| X | 0 | $Q_0$ | $Q_0$ |

- ° Input value D is passed to output Q when C is high
- $^{\circ}$  Input value D is ignored when C is low



- ° Z only changes when E is high
- ° If E is high, Z will follow X



- The D latch stores data indefinitely, regardless of input D values, if C = 0
- Forms basic storage element in computers

# Symbols for Latches



Fig. 5-7 Graphic Symbols for Latches

- SR latch is based on NOR gates
- ° S'R' latch based on NAND gates
- D latch can be based on either.
- ° D latch sometimes called transparent latch

#### **Summary**

- Latches are based on combinational gates (e.g. NAND, NOR)
- Latches store data even after data input has been removed
- ° S-R latches operate like cross-coupled inverters with control inputs (S = set, R = reset)
- With additional gates, an S-R latch can be converted to a D latch (D stands for data)
- D latch is simple to understand conceptually
  - When C = 1, data input D stored in latch and output as Q
  - When C = 0, data input D ignored and previous latch value output at Q
- Next time: more storage elements!